and2(true, X) -> X
and2(false, Y) -> false
if3(true, X, Y) -> X
if3(false, X, Y) -> Y
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
first2(0, X) -> nil
first2(s1(X), cons2(Y, Z)) -> cons2(Y, first2(X, Z))
from1(X) -> cons2(X, from1(s1(X)))
↳ QTRS
↳ DependencyPairsProof
and2(true, X) -> X
and2(false, Y) -> false
if3(true, X, Y) -> X
if3(false, X, Y) -> Y
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
first2(0, X) -> nil
first2(s1(X), cons2(Y, Z)) -> cons2(Y, first2(X, Z))
from1(X) -> cons2(X, from1(s1(X)))
ADD2(s1(X), Y) -> ADD2(X, Y)
FIRST2(s1(X), cons2(Y, Z)) -> FIRST2(X, Z)
FROM1(X) -> FROM1(s1(X))
and2(true, X) -> X
and2(false, Y) -> false
if3(true, X, Y) -> X
if3(false, X, Y) -> Y
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
first2(0, X) -> nil
first2(s1(X), cons2(Y, Z)) -> cons2(Y, first2(X, Z))
from1(X) -> cons2(X, from1(s1(X)))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
ADD2(s1(X), Y) -> ADD2(X, Y)
FIRST2(s1(X), cons2(Y, Z)) -> FIRST2(X, Z)
FROM1(X) -> FROM1(s1(X))
and2(true, X) -> X
and2(false, Y) -> false
if3(true, X, Y) -> X
if3(false, X, Y) -> Y
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
first2(0, X) -> nil
first2(s1(X), cons2(Y, Z)) -> cons2(Y, first2(X, Z))
from1(X) -> cons2(X, from1(s1(X)))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
FROM1(X) -> FROM1(s1(X))
and2(true, X) -> X
and2(false, Y) -> false
if3(true, X, Y) -> X
if3(false, X, Y) -> Y
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
first2(0, X) -> nil
first2(s1(X), cons2(Y, Z)) -> cons2(Y, first2(X, Z))
from1(X) -> cons2(X, from1(s1(X)))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
FIRST2(s1(X), cons2(Y, Z)) -> FIRST2(X, Z)
and2(true, X) -> X
and2(false, Y) -> false
if3(true, X, Y) -> X
if3(false, X, Y) -> Y
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
first2(0, X) -> nil
first2(s1(X), cons2(Y, Z)) -> cons2(Y, first2(X, Z))
from1(X) -> cons2(X, from1(s1(X)))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
FIRST2(s1(X), cons2(Y, Z)) -> FIRST2(X, Z)
POL( FIRST2(x1, x2) ) = 3x2 + 2
POL( cons2(x1, x2) ) = 3x2 + 3
POL( s1(x1) ) = max{0, -3}
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
↳ QDP
and2(true, X) -> X
and2(false, Y) -> false
if3(true, X, Y) -> X
if3(false, X, Y) -> Y
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
first2(0, X) -> nil
first2(s1(X), cons2(Y, Z)) -> cons2(Y, first2(X, Z))
from1(X) -> cons2(X, from1(s1(X)))
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDPOrderProof
ADD2(s1(X), Y) -> ADD2(X, Y)
and2(true, X) -> X
and2(false, Y) -> false
if3(true, X, Y) -> X
if3(false, X, Y) -> Y
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
first2(0, X) -> nil
first2(s1(X), cons2(Y, Z)) -> cons2(Y, first2(X, Z))
from1(X) -> cons2(X, from1(s1(X)))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
ADD2(s1(X), Y) -> ADD2(X, Y)
POL( s1(x1) ) = x1 + 1
POL( ADD2(x1, x2) ) = 2x1 + 3x2 + 2
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
and2(true, X) -> X
and2(false, Y) -> false
if3(true, X, Y) -> X
if3(false, X, Y) -> Y
add2(0, X) -> X
add2(s1(X), Y) -> s1(add2(X, Y))
first2(0, X) -> nil
first2(s1(X), cons2(Y, Z)) -> cons2(Y, first2(X, Z))
from1(X) -> cons2(X, from1(s1(X)))